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Amendments to the Claims : 

The following listing of claims will replace all prior versions, and listings, of claims in 
the application: 

1-4. (Canceled) 

5. (Currently Amended) A method for performing parallel sorting processing 
using a parallel processor, where (i) one unsorted data string, or (ii) two or more sorted partial 
data strings are received as an input, the method comprising: 

if the input is one unsorted data string, a first step of dividing the unsorted data 
string and acquiring to generate a plurality of unsorted partial data strings; 

a second step of assigning a processor to said plurality of unsorted partial data 
strings respectively; 

a third step of sorting each of said plurality of partial data strings 
independently by the assigned processor based on an arbitrary algorithm, to acquire generate 
sorted partial data strings, the plurality of unsorted partial data strings being sorted each in 
one of either ascending or descending order; 

a fourth step of creating an input data string pair for sorting using two of the 
sorted partial data strings which were acquired in the third step or a seventh step or that were 
received as the input, and dividing the pair into sets of partial data string pairs respectively 
under a predetermined division condition; 

a fifth step of editing control information relating to parallel processing of 
merge processin g, the control information for parallel sorting of the plurality of divided 
partial data string pairs; 

a sixth step of assigning to the plurality of divided partial data string pairs a 
processor group for merging of the plurality of divided partial data string pairs; 
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the seventh step of performing merge processing by the assigned processor and 
outputting sorted partial data strings; and 

a step of repeating said fourth step to said seventh step using the merge- 
processed sorted partial data strings as said sorted partial data strings, wherein the above steps 
are applied when one unsorted data string is provided, and the first to the third steps are 
unnecessary if two or more sorted data strings are provided, and a repeat of said fourth to 
seventh steps ends when the merge-processed sorted partial data strings are merged into one 
data string; 

if only two sorted data strings are provided, the fourth to seventh steps are 
executed only once, and the repeat is not required. 

6. (Previously Presented) The parallel sorting processing method according to 
Claim 5, wherein two processors are assigned to said partial data string pair in said sixth step, 
and the control information relating to parallel processing of merge processing is edited in the 
fifth step so that a first processor performs merge processing in descending order from a side 
of which a key value is greater in said partial data string and a second processor performs 
merge processing in ascending order from an edge of which a key value is smaller in the same 
partial data string simultaneously in said seventh step. 

7. (Previously Presented) The parallel sorting processing method according to 
Claim 5, wherein the following items are satisfied as the predetermined division condition in 
said fourth step, 

when a condition where data string pair (Dj, n) and (D 2 , n) are divided into 
two partial data string pairs {(D n , nn), (D 2 i, n 2 i)} and {(D ]2 , n !2 ), (D 22 , n 22 )}, is established, 
and also 

n] ] + n 2 i = 2x, nj 2 + n 22 = 2 (n - x) 
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is established, where x is a half value of the number of data of the partial data string pair 
{(Dn, mi), (D 2 i, n 2 i)}, and is also the number of data of Dn and D 2 i when n u = n 2 i. 

8. (Currently Amended) The parallel sorting processing method according to 
Claim 7, wherein said fourth step has the following functions: 

(1) An-an operation to divide a sorted data string pair {(Di, n), (D 2 , n)} into k 
sets of segment pairs, which is equivalent to performing (k-1) sets of two-division operations 
in which a total of the number of data counted from a first part of Dj and D 2 becomes 2x with 
changing a value of x, while considering a magnitude of the key values of both data strings; in 
this case, a sub-division problem of the sorted data string pair {(Dj, n), (D 2 , n)} to the k sets 
of segment pairs is replaced with the above-mentioned two-division problem of the data 
string that satisfies the items as the division condition in the fourth step; 

(2) Sp e cifying specifying a data position in the data string by an index value, 
the value sequentially increments with the index value of a first data in the data string Di or 
D 2 as 0, x indicates the number of data, but if the value of x itself is regarded as an index 
value, then [x] indicates the (x+l)th data counted as 1, 2, 3, . . . from the first part of the data 
string; 

if rii 1 = n 2 i, then nn = n 2 | = x, which is a formula indicating the number of 
data, can be interpreted that the position of the xth data counted from the first part, that is data 
with the index value x-1, is at a division boundary of Dj and D 2 ; 

(3) An-an area dividing function, comprising: 

a step of setting said x as an initial value of a boundary index value for index 
variables i and j for specifying individual data in said data strings Di and D 2 ; 

a comparison step of comparing a key value of data indicated by the index 
variable i of the data string Di and a key value of data indicated by the index variable j of the 
data string D 2 ; 
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a step of adding 1 to an index variable of the data with a greater key value, 
subtracting 1 from an index variable of the data with a smaller key value, then branching 
processing to said comparison step, if the key value of the data indicated by the index variable 
i of Dj and the key value of the data indicated by the index variable j of D2 are not the same in 
an initial comparison; 

a step of adding 1 to the index variable of data with a greater key value, and 
subtracting 1 from the index variable of data with a smaller key value, then branching 
processing to said comparison step, if a magnitude relationship of the key value of data 
indicated by the index variable i of Di and the key value of data indicated by the index 
variable j of D 2 is unchanged in a second or later comparison; 

a step of regarding the data indicated by the index variable i and the data 
indicated by the index variable j as a division boundary respectively, if the key value of the 
data indicated by the index variable i of Di and the key value of the data indicated by the 
index variable j of D 2 are the same in the initial comparison; and 

a step of comparing a greater one of the key value of Di and the key value of 
D2 in a previous comparison operation with the greater one of the key value of Di and the key 
value of D2 in a current comparison operation, and regarding the data with a smaller key value 
as the division boundary and regarding the data initially compared with this data as the other 
boundary, if the magnitude relationship between the key value of the data indicated by the 
index variable i of Di and the key value of the data indicated by the index variable j of D 2 is 
inverted from a previous magnitude relationship. 

9. (Currently Amended) The parallel sorting processing method according to 
Claim 7, wherein said fourth step has the following functions: 

(1) Aft-an operation to divide a sorted data string pair {(Di, n), (D 2 , n)} into k 
sets of segment pairs, which is equivalent to performing (k-1) sets of two-division operations 
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in which the total of the number of data counted from the first part of Dj and D2 becomes 2x 
with changing the value of x, while considering a magnitude of key values of both data 
strings; 

(2) Specifying specifying a data position of the data string by an index value, 
the value sequentially increments with the index value of a first data in Dj or D 2 as 0, x 
indicates the number of data, but if the value of x itself is regarded as an index value, then [x] 
indicates the (x+l)th data counted from the first part in the data strings; 

if nj 1 = n 2 i, then ni 1 = n 2 i = x indicates that the division boundary of Di and D 2 
exists at the position of the xth data counted from a first part, that is at the data position of the 
index value x-1; 

(3) An-an area division function, comprising: 

a step of setting said x-1 as an initial value of a boundary index value for index 
variables i and j for specifying individual data in said data strings Dj and D 2 ; 

a comparison step of comparing a key value of data indicated by the index 
variable i of the data string Di and a key value of data indicated by the index variable j of the 
data string D 2 ; 

a step of adding 1 to an index variable of the data with a greater key value, 
subtracting 1 from an index variable of the data with a smaller key value, then branching 
processing to said comparison step, when the key value of the data indicated by the index 
variable i of Di and the key value of the data indicated by the index variable j of D 2 are not 
the same in an initial comparison; 

a step of adding 1 to an index variable of the data with a greater key value, 
subtracting 1 from an index variable of the data with a smaller key value, then branching 
processing to said comparison step, if a magnitude relationship of the key value of the data 
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indicated by the index variable i of Di and the key value of the data indicated by the index 
variable j of D 2 is unchanged in the second or later comparison; 

a step of regarding the data indicated by the index variable i and the data 
indicated by the index variable j as a division boundary respectively, when the key value of 
the data indicated by the index variable i of Di and the key value of the data indicated by the 
index variable j of D2 are the same in the initial comparison; and 

a step of comparing the smaller one of the key value of Di and the key value of 
D2 in the previous comparison operation with the smaller one of the key value of Di and the 
key value of D 2 in the current comparison operation, and regarding the data with a greater key 
value as a division boundary, and regarding the data initially compared with this data as 
another boundary, if the magnitude relationship between the key value of the data indicated 
by the index variable i of Dj and the key value of the data indicated by the index variable j of 
D 2 is inverted from a previous magnitude relationship. 

10. (Canceled) 

1 1 . (Currently Amended) A computer readable storage medium that stores a 
program for performing parallel sorting processing using a parallel processor which includes 
a plurality of processors, where (i) one unsorted data string, or (ii) two or more sorted partial 
data strings are received as an input, the program comprising instructions that execute: 

if the input is one unsorted data string, a first step of dividing the unsorted data 
string and acquirin g to generate a plurality of unsorted partial data strings; 

a second step of assigning a processor to said plurality of unsorted partial data 
strings respectively; 

a third step of sorting each of said plurality of unsorted partial data strings 
independently by the assigned processor based on an arbitrary algorithm, to generate sorted 
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partial data strings, the plurality of unsorted partial data strings being sorted each in one of 
either ascending or descending order; 

a fourth step of creating an input data string pair for sorting using two sorted 
partial data strings which were acquired - generated in the third step or a seventh step or that 
were received as the input, and dividing the pair into sub-divided partial data string pairs 
respectively under a predetermined division condition; 

a fifth step of editing control information relating to parallel processing of 
merge processin g, the control information for sorting of the divided partial data string pairs; 

a sixth step of assigning a processor group to each of the sub-divided partial 
data string pairs; 

the seventh step of performing merge processing in parallel by the assigned 
processors and outputting sorted partial data strings; and 

a step of repeating said fourth step to said seventh step using the merge- 
processed data strings as said partial data strings, wherein the above steps are applied when 
one unsorted data string is provided, and the first step to the third step are unnecessary if two 
or more sorted data strings are provided, and a repeat of said fourth step to said seventh step 
ends when the merge-processed sorted partial data strings become one data string; 

the fourth step to the seventh step are executed once, and the repeat is not 
•required if two sorted data strings are provided. 
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